! V0 
i Ul 



LAW OFFICES 



!h Barry r. lipsitz 

io 

BRADFORD GREEN, BUILDING 8 

755 MAIN STREET 
MONROE, CONNECTICUT 06468 




PATENTS, TRADEMARKS, COPYRIGHTS 

BARRY R. LIPSITZ TELEPHONE: (203)459-0200 

RALPH F. HOPPIN FACSIMILE: (203)459-0201 



douglas m. McAllister 



BOX PATENT APPLICATION 

Commissioner for Patents 
Washington, D.C. 20231 




Sir: 



Transmitted herewith for filing is the patent application of: 
Inventor(s): 

Guy GECHT whose address is: 1003 Huntington Avenue, San Jose, CA 95129 
and whose citizenship is: United States 

Philip A. LODWICK whose address is: 7225 Garfield Avenue, Richfield, MN 55423 
and whose citizenship is: United States 

Loren SCHOENZEIT whose address is: 4480 Forest Lake Landing, Orono, MN 55364 
and whose citizenship is: United States 

John D. STEINBERG whose address is: 873 Hacienda Way, Millbrae, CA 94030 
and whose citizenship is: United States 

Ofer TENENBAUM whose address is: 3509 La Terrace Circle, San Jose, C A 94123 
and whose citizenship is: Israel 

Title: METHODS AND SYSTEMS FOR THE PROVISION OF PRINTING SERVICES 



APPLICA TION ELEMENTS : 

(1) [X ] Patent Application Specification, including Abstract and claims - 7 1 pages 

(2) [X ] Eleven (11) sheet(s) of formal drawings, together with transmittal letter 

(3) [ ] A check in the amount of $ to cover the [ ] filing fee($ .00 ) and/or [ ] 

Assignment Recordal Fee ($40) is enclosed. 



[ ] Before calculating the fee, cancel claim(s) 

[ ] Before calculating the fee, see copy of Preliminary Amendment filed in parent 
application (attached hereto.) 



BOX PATENT APPLICATION 
Commissioner for Patents 
MGI-176 
October 16, 2000 
Page 2 



Basic Fee 


$ 710.00 


Multiple Dependent Claims ($260.) 




Foreign Language Surcharge ($130.) 






For 


No. 
Filed 




No. Extra 




Rate 






EXTRA 


Total Claims 


108 


20 


88 


X 


$18. 




$ 1584.00 


CLAIMS 


Independent 
Claims 


2 


3 


0 


X 


$80. 




$ 0.00 


TOTAL FILING FEE 




$ 2294.00 



[ ] The Commissioner is hereby authorized to charge any deficiency in the payment of the 
required fee(s) or credit any overpayment to Deposit Account No. 50-0625. 

(4) [ ] Declaration and Power of Attorney form ~ 3 pages 

a. [ ] Newly executed 

b. [ ] Copy from a prior application 

c. [ ] Deletion of inventor(s) - signed statement attached deleting inventor(s) 

named in the prior application. 

(5) [ ] Small Entity Declaration 

a. [ ] Newly executed 

b. [ ] Copy from a prior application. Status still proper and desired. 
A CCOMPANYING APPLICA TION PARTS: 



(6) 



[ ] 



(7) 
(8) 
(9) 

(10) 

(11) 
(12) 



[ 

[x: 

[x; 
[ 



Assignment document 

a. [ ] Newly executed (with $40.00 recordal fee) and separate transmittal 

Form PTO-1595 

b. [ ] Copy from a prior application 

Preliminary Amendment 

Certified Copy of Priority Document, together with separate transmittal letter 

Information Disclosure Statement, together with PTO Form 1449 and copies of cited 
references 

Return receipt postage prepaid postcard 

Express Mail Certificate (Mailing Label No. EL 632260374 US) 
Other: 



BOX PATENT APPLICATION 
Commissioner for Patents 
MGI-176 
October 16, 2000 
Page 3 



(13) [ ] If a CONTINUING APPLICATION, check appropriate box, and supply the requisite 

information below: 

|~| Continuation Q Divisional Q Continuation-in-part (CIP) 
of prior application no.: 
Prior application information: 

Examiner: Group/Art Unit: 

Status: 

FOR CONTINUATION or DIVISIONAL APPLICATIONS only: The entire disclosure of the 
prior application, from which an oath or declaration is supplied under paragraph 4(b) above, is 
considered a part of the disclosure of the accompanying continuation or divisional application 
and is hereby incorporated by reference. The incorporation can only be relied upon when a 
portion has been inadvertently omitted from the submitted application parts. 

(14) [ ] Please amend the specification by inserting before the first line the sentence: 

(15) [ ] This application claims the benefit of Patent Application 

No. filed on . 

(16) [ X ] Correspondence address : 

Barry R. Lipsitz 
Law Offices of Barry R Lipsitz 
755 Main Street, Building 8 
Monroe, CT 06468 
Telephone: (203) 459-0200 

(17) [ X ] Pursuant to the provisions of 37 C.F.R. Sections L10 and 1.53, Applicants 

respectfully request that this application be assigned a serial number and a filing 
date of October 16, 2000 . the date upon which the application was mailed to the 
Patent and Trademark Office by Express Mail (No. EL 632260374 US), 

Respectfully submitted, 




Barry R. Lipsitr 
Attorney for Applicants) 
ATTORNEY DOCKET NO.: MGI-176 Registration No. 28,637 

Date: October 16, 2000 755 Main Street, Bldg. 8 

Monroe, CT 06468 
(203) 459-0200 



PATENT 

IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 



In re Application of: ) 

) 

Gecht et al. ) 

) 

Filed: Herewith ) 

) 

For: METHODS AND SYSTEMS FOR THE PROVISION OF PRINTING SERVICES 

BOX PATENT APPLICATION 
Commissioner for Patents 
Washington, D,C 20231 




"Express Mail" mailing label number: El 632260374 US 
Date of Deposit: October 16, 2000 

I hereby certify that the attached: 

[ x ] Return receipt postage prepaid postcard; 
[ x ] Transmittal letter for new patent application; 

[ x ] Patent Application Specification including Abstract and Claims (7 1 pages); 
[ x ] Eleven (11) sheet(s) of formal drawings, together with transmittal letter. 

are being deposited with the United States Postal Service "Express Mail Post Office to Addressee" 
service under 37 C.F.R. 1.10 and 1.53 on the date indicated above and is addressed to: BOX PATENT 
APPLICATION, Commissioner for Patents, Washington, D.C. 20231 

Michele Hollis L fYl u>iJ ^ ,M 4il) 

(Typed or printed name of person mailing paper or fee) (Signature of person mailing paper or fee) 

Respectfully submitted, 



Date: October 16, 2000 

ATTORNEY DOCKET NO.: MGI-176 Barry R. Lipsitz 

Attorney for Applicant(s) 
Registration No. 28,637 
755 Main Street, Bldg. 8 
Monroe, CT 06468 
(203) 459-0200 




MGI-176 



METHODS AND SYSTEMS FOR THE PROVISION OF PRINTING 
" SERVICES 

BACKGROUND OF THE INVENTION 

The present invention relates to methods and systems 
5 for providing printing services over a communications 

network. In particular, the present invention enables a 
user to obtain print jobs at an unspecified location 
which may be remote from the source of the print job. A 
spooling server is used to store a print job received via 

10 the network from a print job source. A printer polling 

device, which may be at a location remote from the print 
job source, is capable of polling the spooling server via 
the network to identify whether any print jobs associated 
with the printer polling device are available for 

15 printing at one or more associated printers. A fee can be 

charged for the printing services provided. 

As computer networks become more complex, the rate 
at which network configurations change continues to 
increase. Also, the increasingly frantic pace of the 

20 typical business traveler who juggles documents on 

multiple computers and is required to configure a 
traveling laptop computer to integrate into various 
changing networks makes it increasingly difficult to 
reliably and efficiently print even a simple document. 
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For example, a business traveler in a hotel may wish 
to print to a printer that the hotel provides for such 
purposes. Under the current state of the art, the user 
must first obtain the network ID of the printer along 
5 with some information about the type of printer. Then, a 

print driver for that specific printer must be installed 
on the user's computer, and the computer must be 
configured to connect to the printer. This may 
additionally involve configuring the computer to connect 

10 to the host network. 

Further, in many cases, it is desirable to be able 
to prepare a document for printing prior to having the 
information concerning the destination printer. For 
example, it may be desirable to print a document from a 

15 mobile laptop connected via a wireless data connection 

while in transit to a meeting at a site the user has 
never visited before. Obtaining the information and 
configuring the laptop to be able to print to the printer 
becomes logistically infeasible. 

20 These problems have typically been solved in the 

past by one of the following methods: 

1. The document is e-mailed or otherwise transferred 
over a network to a computer already configured to print 
to the desired printer; 

25 2. A portable computer is connected directly to the 

printer via a cable or infra-red, bypassing many of the 
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difficulties of configuring the computer to print to a 
network computer; 

3. A portable printer is transported to the desired 
location; or 

5 4. The document is faxed to a fax machine. 

Printing methods relating to network and distributed 
printing are known in the prior art. Such systems require 
either a private network or foreknowledge of the 
destination of a print job. These prior art methods 

10 comprise what is typically referred to as "push" 

technology (i.e. technology in which a print job is 
directed to a specific known destination or printer) . 

In addition to the need for efficiency and ease of 
use is the need for security when sending, storing, or 

15 printing print jobs. Early in the life of the Internet, 

the need for securing an organization's local network 
from tampering, stealing, or vandalism by outsiders 
became very obvious. A type of gateway called a firewall 
was developed to meet this need. The firewall is designed 

20 to be a single, well-controlled access point between the 

outside, global, or wide-area network and the inside, 
local-area network. By carefully restricting the types of 
network traffic and the destinations where that traffic 
can flow, the firewall can provide effective protection. 
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Specific "holes" in the firewall are created for 
each type of traffic that is allowed through the gateway 
in each direction. Most organizations, for example, allow 
e-mail traffic in and out from their e-mail server, as 
5 well as web page client access from inside the firewall 

to servers located outside of it. 

Many types of access between machines commonly used 
on a local network are normally prevented from going 
through the firewall. Specifically, file sharing, remote 

10 log-in, printing, and various other network- 

administration types of protocols are typically not 
allowed to be transported outside the firewall. 

Another aspect of the firewall is that it is almost 
always administratively controlled by a centralized 

15 authority for the organization that owns the local area 

network - commonly the management information services 
(MIS) department of a company. Normal users generally 
have to make special requests that are approved at the 
upper levels of management to get configuration changes 

20 in the firewall. In the interest of maintaining security, 

these changes are often limited to specific point-to- 
point exceptions or "holes" in the firewall. 

It is desirable by many users to be able to print 
from a machine on one local area network to a printer 

25 located on a different local area network with the data 
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being transferred over a global network (e.g., the 
Internet) outside of the firewall of both local networks. 

The current state of the art does have solutions for 
this problem. However, almost all of these solutions 
5 require the intervention of the firewall administrator. 

One example of a solution is the IPP - Internet Printing 
Protocol standard being promulgated by various vendors. 
This standard allows IPP-equipped printers to receive 
print jobs from remote clients over the Internet. 

10 However, the installation and use of IPP requires that a 

specific IPP hole be opened in the firewall by the 
network administrator. 

It would be advantageous to be able to provide 
methods and systems that allow a user to print to a 

15 perhaps yet unknown destination printer or printer pool 
in a reliable, efficient and secure manner without the 
disadvantages of the above-mentioned techniques. 

It would be further advantageous to provide a 
printing system based on "pull" technology (i.e. 

20 technology which enables a print job to be printed upon 

request, where the print file is only delivered in 
response to said request) . Such technology would enable a 
system that allows a user to print to a destination 
printer or printer pool that may be located anywhere, in 

25 a reliable, efficient, and secure manner without the 

disadvantages of the above-mentioned techniques. 
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It would be further advantageous to have a solution 
that allows secure, efficient and easy-to-conf igure 
inter-network printing through a gateway firewall without 
the intervention of the network administrator. 

It would be still further advantageous to make such 
printing services available to a user for a fee. 

The methods and systems of the present invention 
provide the foregoing and other advantages. 
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SUMMARY OF THE INVENTION 

The present invention relates to methods and systems 
for providing printing services over a communications 
network. In particular, the present invention enables a 
5 user to obtain print jobs at a location which may be 

unspecified, and which may be remote from the source of 
the print job. A spooling server is used to store a print 
job received via the network from a print job source. A 
printer polling device, which may be used at a location 

10 remote from the source of the print job, is capable of 

polling the spooling server via the network to identify 
whether any print jobs associated with the printer 
polling device are available for printing at one or more 
printers associated with the polling device. A variety of 

15 revenue models may be used for the printing services 

provided. 

In a preferred embodiment, printing services are 
provided via a spooling server which is capable of 
receiving and storing one or more print jobs from a print 
20 job source via a network. A printer polling device is 

provided which is capable of polling the spooling server 
via the network to identify a print job associated with 
the printer polling device. 

The print job can originate from any suitable print 
25 job source, such as a client device with an associated 
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print driver, a web browser, a facsimile machine, a 
scanner, a telephone, an Internet appliance, a personal 
digital assistant, or the like. A print job can also 
originate on the spooling server itself or be obtained 
from another server. The client device may be a computer, 
a telephone, a personal digital assistant, an Internet 
appliance, or the like. 

The identified print job can be transmitted from the 
spooling server to the printer polling device and printed 
at one or more printers coupled to the printer polling 
device . 

The printer polling device may periodically poll the 
spooling server to identify a print job associated with 
the printer polling device. 

The network may comprise at least one of a local 
area network, a wide area network, a global network, the 
Internet, and any other type of network. The network may 
consist of multiple interconnected networks having 
multiple gateways and other features as is well known in 
the art. 

In an alternate embodiment, the printer polling 
device may be located within a gateway firewall and the 
spooling server may be located outside the gateway 
firewall. The print job may be forwarded to the spooling 
server such that reconfiguration of the gateway firewall 
is not required. For example, the print job may be 
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forwarded to the spooling server as web-style traffic and 
received at the printer polling device as web-style 
traffic . 

The print job source may be located at and in 
5 communication with a first local area network and the 

printer polling device may be located at and in 
communication with a second local area network. The 
spooling server may be located outside of the first and 
second local area networks. The print job source may 

10 communicate with the spooling server via a first gateway 

firewall which controls access to the first local area 
network and the printer polling device may communicate 
with the spooling server via a second gateway firewall 
which controls access to the second local area network. 

15 The printer polling device may be: (i) a stand-alone 

device connected to one or more printers via a standard 
printer port, (ii) integrated into the firmware of a 
printer, (iii) integrated into the software of a network 
print server, or (iv) of any other suitable 

20 configuration. 

In an illustrative embodiment, a fee may be charged 
to access the spooling server. The fee can be based on 
one of print job size in bytes, print job size in number 
of pages, print job type, time for printing, time for 

25 storage, monthly fee, per use fee, lifetime membership, 

monthly membership, use of color, use of black and white, 
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page size, location, convenience, number of images, print 
quality, image quality, or other suitable factors. The 
fee may be charged for providing a print job to the 
spooling server and/or retrieving a print job from the 
5 spooling server. The fee can be paid via a client device 

associated with the print job source, the printer polling 
device, or other suitable device, such as a smart card, a 
telephone, a personal digital assistant, or the like. 

In another illustrative embodiment, one or more of 

10 the print job source application software, spooling 

server, and printer polling device may be sold, licensed, 
leased, rented, or distributed freely for revenue 
generating purposes. The print job source application 
software, spooling server, and printer polling device may 

15 be owned and/or operated by the same entity, or by 
different entities . 

Print job source application software may be 
distributed to end users on a royalty-bearing or royalty- 
free basis, and the end user may be charged a fee for 

20 each print job submitted to a spooling server, and/or for 

each job retrieved from a spooling server. 

The spooling server may be sold, rented, licensed or 
distributed freely to a print server provider. The print 
server provider may be, for example, a corporation, 

25 university, government agency, or other similar entity. 

The print server provider may provide services to end 
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users for a fee for providing a print job to the spooling 
server and/or retrieving a print job from the spooling 
server . 

The printer polling device may be sold, rented, 
5 licensed or distributed freely. Printer polling devices 

may be provided for customer use at coffee shops, hotels, 
airports, libraries, bookstores, post offices, 
supermarkets, kiosks, print shops, retail outlets, or 
other suitable locations. End users of the printer 
10 polling device may be charged a fee for using the device. 

The spooling server may store the one or more print 
job(s) in at least one spooling queue. 

The print job may be encrypted at the print job 
source and decrypted at the printer polling device. 
15 The print job may comprise a document provided by a 

content provider. The content provider may be one of a 
newspaper, a magazine, a periodical, a document provider, 
a graphic arts provider, a notification service, an 
Internet content provider, a merchant, a financial 
20 institution, a government agency, a shipping company, or 

the like. 

The print job may be provided by the content 
provider on a subscription basis. A single print job may 
be provided by the content provider for printing by 
25 multiple users. 
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The printer polling device may comprise a user 
interface, a connection to the network, and a connection 
to one or more printers. 

In a further embodiment, each print job may be 
5 stored on the spooling server according to a personal 

identification number (PIN) . The spooling server may 
communicate to the printer polling device a list of print 
jobs associated with the PIN which are stored at the 
spooling server. The selection of a print job from the 

10 list may be provided for (e.g., via a user interface). 

A plurality of print jobs may be stored on the 
spooling server according to the PIN . The PIN may be 
provided to the spooling server via one of a user 
interface associated with the printer polling device, a 

15 telephone, a computer, an Internet appliance, a facsimile 

machine, a scanner, a personal digital assistant device, a 
dedicated terminal, or the like. The list of available 
print jobs may be displayed on one of a user interface 
associated with the printer polling device, a telephone, 

20 a computer, an Internet appliance, a facsimile machine, a 

scanner, a personal digital assistant device, a dedicated 
terminal, or the like. Selection of an available print job 
may be made via a user interface associated with the 
printer polling device, a telephone, a computer, an 

25 Internet appliance, a facsimile machine, a scanner, a 



13 



MGI-176 



personal digital assistant device, a dedicated terminal, 
or the like. 

The printer polling device may be a portable device. 
The printer polling device may be operably associated 
5 with a variety of printer types. 

In a further embodiment, the print job may be 
provided to the spooling server without a pre-determined 
print destination. Alternatively, a desired print 
location for the print job may be designated at the print 
10 job source. The designated print location may be 

communicated to the spooling server with the print job. 
The print job may be printed at the desired print 
location when the printer polling device at the desired 
print location polls the spooling server and identifies 
15 the print job. 

Further, a substantially specific time for printing 
a print job may be designated such that the print job is 
only available for printing from the spooling server at 
the designated substantially specific time. 
20 In addition, a lifetime of the print job may be 

designated, wherein said print job will be stored on the 
spooling server only for the designated lifetime. 

A number of printings of the print job may be 
designated, wherein the print job can only be printed the 
25 designated number of times. 
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A list of recipients authorized to retrieve a print 
job may be designated, wherein the print job may only be 
printed by the designated recipients. 

The print job may be one of a negotiable instrument, 
5 a stamp, a coupon, a certificate, a check, a unit of 

currency, a token, a receipt, or the like. 

The print job source may be connected to the network 
using Dynamic Host Configuration Protocol (DHCP 
protocol), or any other suitable network configuration 
10 protocol. Similarly, the printer polling device may be 

connected to the network using DHCP protocol, or any 
other suitable network configuration protocol. 

In a preferred embodiment, the printer polling 
device is capable of communicating printer status to the 
15 spooling server. The printer status may comprise at least 

one of a printer ready indication, an on-line indication, 
toner level information, paper supply information, error 
information, or other appropriate status information. 

A printer operator can be notified when the printer 
20 status indicates that a printer requires attention. The 

operator can also be provided with vendor contact 
information to facilitate obtaining printer supplies or 
service. Automatic on-line ordering of printer supplies 
as required by printer status can be provided (e.g., by 
25 the spooling sever contacting predetermined preferred 

vendors) . 
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The print job may include at least one of a 
document, a poster, an image, a coupon, a ticket, a 
certificate, a check, a list, a schedule, a periodical, a 
unit of currency, a negotiable instrument, postage, a 
5 bill of lading, a lottery or gaming ticket, a token, food 

stamps, a license, a permit, a pass, a passport, a 
ballot, a citation, identification, a copy-protection 
key, a proof-of-purchase, a warranty, a receipt, a 
transcript, a library card, or any other printable 

10 subject matter. 

In an alternate embodiment, an agent program 
provides a directory of documents to the spooling server. 
The agent program enables a client device associated with 
the print job source to poll the spooling server to 

15 determine whether the spooling server requires a document 

identified in the directory to complete a print job. If 
so, the document can be uploaded from the client device 
to the spooling server. 

The directory can be communicated to the printer 

20 polling device and presented at the printer polling 

device. Selection of a print job from the directory can 
be made (e.g., via a user interface). 

The directory may be presented via a visual 
presentation or an audio presentation. The client device 

25 may periodically poll the spooling server to determine 
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whether the spooling server requires a document 
identified in the directory to complete a print job. 

Communications with the spooling server may be 
enabled via at least one of a telephone, a personal 
5 digital assistant device, a computer, an Internet 

appliance, a web browser, a dedicated terminal, or the 
like. The communications with the spooling server may be 
via an audio interface or a visual interface. 

A communication device for providing status of the 
10 print job stored on the spooling server may be provided. 

The status of the print job may comprise at least one of 
filename, file size, author, creation date, print job 
lifetime, image, title, contents, personal identification 
number, recipient, job number, or reference number. The 
15 communication device may be a telephone, a computer, an 

Internet appliance, a personal digital assistant device, 
a dedicated terminal, or any other suitable wireless or 
wired communication device. 

The print job source may be one of a computer, a 
20 personal digital assistant device, an Internet appliance, 

a facsimile machine, a scanner, a telephone, a dedicated 
terminal, or other suitable source. 

The printer polling device may be capable of polling 
multiple spooling servers. 
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The spooling server may be capable of communicating 
with other servers and receiving a print job from at 
least one of the other servers. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a block diagram of an implementation of 

the present inventions- 
Figure 2 is a flow diagram showing an example of an 
5 encryption process which can be implemented in accordance 

with the invention; 

Figure 3 shows a representation of a printer polling 

device; 

Figure 4 is a block diagram of an alternate 
10 embodiment of the invention; 

Figure 5 is a flow diagram of an authentication 
procedure which can be implemented in accordance with the 
invention; 

Figure 6 shows an example of communications which 
15 take place between various components of the invention; 

Figure 7 is a flow chart illustrating an example 
print job reformatting routines- 
Figure 8 is a block diagram of an embodiment of a 
printer polling device; 
20 Figure 9 is a block diagram of an embodiment of a 

spooling server; 

Figure 10 is a block diagram of an embodiment of a 
print driver; and 

Figure 11 is a block diagram of an embodiment of an 
25 agent program. 
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DETAILED DESCRIPTION OF THE INVENTION 

The present invention enables print jobs to be sent 
to a spooling server for storage. The print jobs are 
subsequently delivered to one or more printers, on 
5 request, via a printer polling device. The printer 

polling device uses "pull" technology, which polls the 
spooling server so that the spooling server does not have 
to initiate a connection into a printer. In this manner 
print jobs can be securely printed anywhere, either 

10 automatically or at the request of a user who is 

authorized by the printer polling device and/or the 
spooling server. Since the spooling server need not 
initiate contact with any device, there is no potential 
breach of firewall security in a local network 

15 environment. 

In one embodiment, a portable printer polling device 
is provided to enable retrieval and printing of documents 
from any location having Internet access and a printer. 
The spooling server functions as a repository that is 

20 accessible, e.g., via a global communication network such 

as the Internet, to authorized users at any time of day. 
Since the printer polling device polls the spooling 
server in order to obtain delivery of a print job, prior 
art push data flow techniques, which could compromise a 

25 local area network's security, are avoided. Moreover, 
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compatibility with virtually all printers that may be 
connected to the network is provided, so that a document 
can be printed anywhere regardless of a specific 
printer's requirements. Many other advantages and 
5 features of the invention are set forth in the following 

description . 

An illustrative embodiment of the invention is shown 
in Figure 1. Printing services are provided via a 
spooling server 50 which is capable of receiving and 

10 storing one or more print jobs from a print job source 10 

via a network 110. A printer polling device 100 is 
provided which is capable of polling the spooling server 
50 via the network 110 to identify a print job associated 
with the printer polling device 100. Configuration 

15 problems are eliminated as each print job source 10 only 

needs to be configured to know how to print to the 
spooling server 50. The spooling server 50 only needs to 
be configured to be able to print to the printer polling 
device 100. 

20 The print job can originate from any suitable print 

job source 10, As shown in Figure 1, the print job source 
10 may be a client device 12 associated with print driver 
14. The print driver 14 may receive the print job from an 
originating application 15, which can be any program 

25 capable of producing a printable document. The print job 

source 10 may also be a web browser, a facsimile machine, 
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a scanner, a telephone, an Internet appliance, a personal 
digital assistant, or the like. A print job can also 
originate on the spooling server 50 itself or be obtained 
from another server. The client device 12 may be a 
5 computer, a telephone, a personal digital assistant, an 

Internet appliance, a facsimile machine, a scanner, or 
the like. 

The identified print job can be transmitted from the 
spooling server 50 to the printer polling device 100 and 

10 printed at a printer 120 coupled to the printer polling 

device 100. Printer 120 may be a single printer or a pool 
of one or more printers coupled via a print server. 

The printer polling device 100 may periodically poll 
the spooling server 50 to identify a print job associated 

15 with the printer polling device 100. Security is achieved 

by the fact that the printer 120 is not passively 
accepting any and all connections from the outside. The 
printer polling device 100 is initiating connections to a 
specific, trusted location, the spooling server 50. 

20 The network 110 may comprise at least one of a local 

area network, a wide area network, a global network, the 
Internet, and any other type of network. The network 110 
may consist of multiple interconnected networks having 
multiple gateways and other features as is well known in 

25 the art. 
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In an alternate embodiment , the printer polling 
device 100 may be located within a gateway firewall 70 
and the spooling server may be located outside the 
gateway firewall 70. In addition, the print job source 10 
5 may be located within a gateway firewall 30 and the 

spooling server may be located outside the gateway 
firewall 30 . 

The print job may be forwarded to and from the 
spooling server 50 such that reconfiguration of gateway 

10 firewalls 30 and 70 is not required. For example, the 

print job may be forwarded to the spooling server 50 as 
web-style traffic and received at the printer polling 
device 100 as web-style traffic. For example, a print 
driver 14 may accept print requests from application 15 

15 like any other print driver, but instead of routing the 

print requests onto the network 110 using normal printer 
packets and well-known-ports, it routes the output of the 
print job to the spooling server 50 located outside of 
the firewall 30 using packets and ports that resemble web 

20 traffic. 

Similarly, using web types of packets and ports, the 
printer polling device 100 is capable of polling the 
spooling server 50 and retrieving any print jobs that 
have been stored for the printer 120. 

25 As shown in Figure 1, the print job source 10 may be 

located at and in communication with a first local area 
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network 20 and the printer polling device 100 may be 
located at and in communication with a second local area 
network 80. The spooling server 50 may be located outside 
of the first and second local area networks 20, 80. The 
5 print job source 10 may communicate with the spooling 

server 50 via a first gateway firewall 30 which controls 
access to the first local area network 20 and the printer 
polling device 100 may communicate with the spooling 
server 50 via a second gateway firewall 70 which controls 

10 access to the second local area network 80. 

The printer polling device 100 may be: (i) a stand- 
alone device connected to the printer 120 via a standard 
printer port, (ii) integrated into the firmware of the 
printer 120, (iii) integrated into the software of a 

15 network print server, or (iv) of any other suitable 

configuration. The printer polling function may also be 
integrated into the software on a stand-alone print 
server such as those manufactured by Electronics for 
Imaging, Inc. (Foster City, California) under the 

20 trademarks Fiery® and EDOX®. 

In a preferred embodiment, a fee may be charged to 
access the spooling server 50. The fee can be based on 
one of print job size in bytes, print job size in number 
of pages, print job type, time for printing, time for 

25 storage, monthly fee, per use fee, lifetime membership, 

monthly membership, use of color, use of black and white, 
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page size, location, convenience, number of images, print 
quality, image quality, or other suitable factors. The 
fee may be charged for providing a print job to the 
spooling server 50 and/or retrieving a print job from the 
5 spooling server 50. The fee can be paid via a client 

device 12 associated with the print job source 10, the 
printer polling device 100, or any other suitable device 
capable of communicating with the spooling server, such 
as a smart card, a telephone, a personal digital 

10 assistant, or the like. 

The spooling server 50 may store the one or more 
print job(s) in at least one spooling queue 52. The 
spooling server 50 may be maintained by a trusted party 
on the outside of the firewalls 30, 70. Alternatively, 

15 the spooling server 50 may be owned and maintained by the 

organizations desiring to utilize inter-network printing. 

Since the communications amongst the print job 
source 10, the spooling server 50, and the printer 
polling device 100 may travel across public networks, it 

20 is very desirable to protect any proprietary or 

confidential information that may be embodied in the 
print jobs. 

In a preferred embodiment, the print job may be 
encrypted at the print job source 10 and decrypted at the 
25 printer polling device 100. For example, the print job 

can be encrypted on the client device 12 such that it can 
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only be printed by a person with the correct decryption 
key. In addition, printing of the document can be delayed 
until the key is physically entered at the printer 
polling device 100 (e.g., the recipient is physically 
5 present at the printer 120) . 

A flow diagram of an example of an encryption 
process used between the print job source 10, the 
spooling server 50 and the printer polling device 100 is 
shown in Figure 2. The print job 11 is protected by 

10 encrypting the print job (indicated at 501) at the print 

job source 10 (e.g., on the print driver 14 or an agent 
program on the originating client device 12 of Figure 1) 
and decrypting it at the spooling server 50. The 
encryption algorithm may be the IDEA algorithm. Other 

15 suitable encryption algorithms which can be utilized are 

DES (the Data Encryption Standard), or triple-DES (DES 
applied to the data three times with three different 
keys) . Other encryption algorithms suitable for 
commercial confidential information are numerous and well 

20 known in the art of data encryption. 

The key 500 used for encryption 501 may be derived 
from an account number 510, a user's secret PIN (personal 
identification number) 520, and/or optionally some 
additional encryption key digits 530 supplied by the 

25 user. Simply concatenating the bits together from these 

sources provides a moderately secure key 500. Optionally, 
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additional security may be achieved by using a more 
sophisticated hashing function. 

The key 500 would be known only to the user and to 
the secure, trusted, spooling web server 50. The 
5 encrypted print job is sent to the spooling server 50 

where it is decrypted (601) to facilitate reformatting 
602 for the destination printer once it is known. The 
reformatted print job data is re-encrypted 603 using the 
same or similar key 500' derived in the same manner as 

10 key 500 at the print job source 10. The encrypted print 

job is then transmitted from the spooling server 50 to 
the printer polling device 100. Once at the printer 
polling device 100, the print job is decrypted 701 using 
a key 500'' derived from the PIN 520, account number 510, 

15 and/or optional encryption key extension digits 530. The 

decrypted print job can then be forwarded to the printer 
120 for printing. 

The print job 11 may comprise a document provided by 
a content provider. The content provider may be one of a 

20 newspaper, a magazine, a periodical, a document provider, 

a graphic arts provider, a notification service, an 
Internet content provider, a merchant, a financial 
institution, a government agency, a shipping company, or 
the like. For example, instead of physically delivering 

25 the daily sports page, it is simply printed on a 

customer's home printer. 
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The print job 11 may be provided by the content 
provider on a subscription basis. A single print job may 
be provided by the content provider for printing by 
multiple users, 

5 The printer polling device 100 may comprise a user 

interface, a connection to the network 110, and a 
connection to the printer 120. Figure 3 shows an 
embodiment of a user interface 103 for the printer 
polling device 100 having a display 101 and a keypad 102. 

10 The keypad 102 shown in Figure 3 may also comprise an 

alphanumeric keypad to allow for entry of both letters 
and numbers. The user interface may optionally include a 
speaker and a microphone for audio output and input, and 
may also include a card reader for reading a magnetic 

15 strip on a credit or debit card, automated teller machine 

(ATM) card, smartcard, prepaid print card, or the like. 

In a further embodiment as shown in Figure 4, each 
print job may be stored on the spooling server 50 
according to a personal identification number (PIN) 400. 

20 As an example, Figure 4 shows the PIN 400 entered at a 

client device 12. The PIN 400 is forwarded to the 
spooling server 50 by the print driver 14 along with the 
print job. The spooling server 50 may communicate to the 
printer polling device 100 a list of print jobs 

25 associated with the PIN 400 which are stored at the 

spooling server 50. The selection of a print job from the 
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list may be provided for (e.g., via a user interface). 
For example, a small terminal may be provided at each 
printer polling device 100 to allow a user to interact 
with the spooling server 50 and request that the user's 
5 print jobs be sent to the printer 120 at the user's 

location. The user may identify himself or herself at the 
printer polling device 100 with their PIN 400, and the 
spooling server 50 can then match that PIN 400 with print 
jobs previously submitted using that same PIN 400. 

10 A plurality of print jobs may be stored on the 

spooling server 50 according to the PIN 400 (e.g., in 
spooling queue 52) . For example, a directory may be 
created for each user, and thus each PIN, registered with 
the spooling server 50. Each print job may additionally 

15 be assigned a unique job number at the time it is first 

received at the spooling server 50. Thereafter, the job 
number may be used to access the data files associated 
with that job unambiguously. Once a print job has been 
selected to be printed to a destination printer 120, the 

20 job number for the print job may be entered into a queue 

associated with the destination printer 120. Data 
structures suitable for maintaining a queue are well known 
in the art. In the preferred embodiment, the queue 52 is 
maintained in a C++ class known as a CList provided by 

25 Microsoft in their C++ class library. 
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When the printer polling device 100 polls the 
spooling server 50, the spooling server 50 checks to see 
if the queue for that printer 120 contains any print 
jobs. When the spooling server 50 finds a print job 
5 waiting to be printed, the data for that print job is 

retrieved from the file system, reformatted in a form 
suitable for the identified printer 120, and transmitted 
to the printer polling device 100. 

The PIN 400 may be provided to the spooling server 

10 50 via one of a user interface associated with the 

printer polling device 100, a telephone, a computer, an 
Internet appliance, a facsimile machine, a scanner, a 
personal digital assistant device, a dedicated terminal, 
or the like. The list of available print jobs may be 

15 displayed on one of a user interface associated with the 

printer polling device 100, a telephone, a computer, an 
Internet appliance, a facsimile machine, a scanner, a 
personal digital assistant device, a dedicated terminal, 
or the like. Selection of an available print job may be 

20 made via a user interface associated with the printer 

polling device 100, a telephone, a computer, an Internet 
appliance, a facsimile machine, a scanner, a personal 
digital assistant device, a dedicated terminal, or the 
like. 

25 Figure 5 illustrates an exemplary process of 

authentication of a user using a PIN. When a user desires 
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to access their account or documents over a non-secure 
channel, first, the spooling server 50 needs to verify 
that it is indeed talking to the actual user. The server 
generates a random string of bits 350. These bits are 
5 sent to the printer polling device 100 where 

authentication is to take place. The user's PIN 150 is 
used to generate an encryption key 152 for encrypting the 
bits (indicated at 155) and the result is returned to the 
spooling server 50. The spooling server 50 decrypts the 

10 string (indicated at 355) using an encryption key 362 

generated from the PIN it knows (360) and compares it to 
the original random string (indicated at 365) . If the 
decrypted string 358 matches the original string 350, the 
spooling server 50 accepts the user as authenticated. An 

15 account number (361, 151) may optionally be used (either 

alone or in connection with the PIN) to generate the 
encryption keys 362, 152. Many other authentication 
protocols are well known in the art and may be 
substituted for the protocol described above in 

20 connection with Figure 5. 

The printer polling device 100 may be a portable 
device. The printer polling device 100 may be operably 
associated with a variety of printer types. 

In a further embodiment, the print job may be 

25 provided to the spooling server 50 without a pre- 

determined print destination. A user is able to interact 
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with the printer polling device 100 and communicate the 
identification of the desired print destination for the 
user's print job to the spooling server 50. The user need 
not know anything more about /the printer 120 than its 
5 location (which the user needs anyway to be able to 

retrieve the physical output pages) . 

Alternatively, a desired print location for the 
print job may be designated at the print job source 10. 
The designated print location may be communicated to the 
10 spooling server 50 with the print job. The print job may 

be printed at the desired print location when the printer 
polling device 100 at the desired print location polls 
the spooling server 50 and identifies the print job. 

Further, a substantially specific time for printing 
15 a print job may be designated such that the print job is 

only available for printing from the spooling server 50 
at the designated substantially specific time. 

In addition, a lifetime of the print job may be 
designated, wherein said print job will be stored on the 
20 spooling server 50 only for the designated lifetime. 

A number of printings of the print job may be 
designated, wherein the print job can only be printed 
from the spooling server 50 the designated number of 
times . 

25 A list of recipients authorized to retrieve a print 

job may be designated, wherein the print job may only be 
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printed by the designated recipients. For example, a 
document or series of documents may be provided to the 
spooling server 50 which document or documents can be 
received by a designated group of recipients, such as a 
5 company's sales fprce, newsgroup or other content 

subscribers, or other target audiences. 

The print job may be one of a negotiable instrument, 
a stamp, a coupon, a certificate, a check, a unit of 
currency, a token, a receipt, or the like. In such 

10 circumstances, it may be desirable that the designated 

number of printings is one. 

The print job source 10 may be connected to the 
network 110 using Dynamic Host Configuration Protocol 
(DHCP protocol), or any other suitable network 

15 configuration protocol. Similarly, the printer polling 

device 100 may be connected to the network 110 using DHCP 
protocol, or any other suitable network configuration 
protocol. 

DHCP is a protocol which allows nodes to be added to 
20 a TCP/IP network dynamically without specific prior 

configuration of that node in the domain controller's 
hosts database. Each node desiring to connect announces 
itself to the DHCP server. The name of the node is sent 
to the DHCP server. The DHCP server then assigns the node 
25 a dynamic IP address as well as communicating the IP 

addresses of other key network services such as name 
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servers, mailhosts, and gateways that are available. Once 
setup and enabled, this mechanism allows nodes to be 
added to the network without the intervention of a 
network administrator. 
5 Ease of installation and configuration is therefore 

achieved through the use of DHCP by the fact that most 
local networks are configured to allow network devices to 
be added without the intervention of an administrator 
using DHCP. In addition, most local networks allow web 

10 access through their firewall (e.g., gateway firewalls 30 

and 70) . These two factors allow both the print job 
source 10 and the printer polling device 100 to connect 
and communicate to the spooling server 50 without the 
intervention of a network administrator. The user simply 

15 plugs in the printer polling device 100 and it accesses 

the network and starts polling the spooling server 50. 

The invention may also be implemented using a virtual 
private network (VPN) . A VPN is a mechanism that allows 
network nodes not directly connected to a local private 

20 network to behave as if they are locally connected to the 

network by forwarding the data packets through some type 
of public or intermediate network. For security, 
authentication of the node desiring to connect to the 
network is performed, as well as encryption of the 

25 contents of the forwarded packets. Various commercial 

products allow the setup and configuration of VPN's 
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through various connectivity mechanisms such as dial-up 
ISP's, Cable Modems, and DSL on the client node end. The 
local network that is being connected to will require a 
router or router/firewall that implements the VPN 
5 protocol to allow the VPN connection. A VPN is made up of 

two components: L2TP (Layer 2 tunneling protocol) and 
IPSEC (Internet Protocol Security) . 

In a preferred embodiment, the printer polling 
device 100 is capable of communicating the status of the 

10 printer 120 to the spooling server 50. The printer status 

may comprise at least one of a printer ready indication, 
an on-line indication, toner level information, paper 
supply information, error information, or other 
appropriate status information. 

15 A printer operator can be notified when the printer 

status indicates that the printer 120 requires attention. 
The operator can also be provided with vendor contact 
information to facilitate obtaining printer supplies or 
service. Automatic on-line ordering of printer supplies 

20 as required by printer status can be provided (e.g., by 

the spooling sever 50 contacting predetermined preferred 
vendors) . 

The print job may include at least one of a 
document, a poster, an image, a coupon, a ticket, a 
25 certificate, a check, a list, a schedule, a periodical, a 

unit of currency, a negotiable instrument, postage, a 
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bill of lading, a lottery or gaming ticket, a token, food 
stamps, a license, a permit, a pass, a passport, a 
ballot, a citation, identification, a copy-protection 
key, a proof -of -purchase , a warranty, a receipt, a 
5 transcript, a library card, or any other printable 

subject matter. 

As illustrated in Figure 6, the printer polling 
device 100 may periodically poll the spooling server 50. 
The interval of the polling can vary as desired and can 

10 be adjusted dynamically based upon such factors as 

traffic or requests for files. The polling request 
(query) 210 is preferably encrypted. Because the query 
210 is directed to a specific spooling server 50, it is 
difficult for a third party to breach the system' s 

15 security. The query 210 asks the spooling server 50 if it 

has a print job identified by the user (e.g., via a PIN 
or a job number) . Once the spooling server 50 has 
received a request 210 from the printer polling device 
100 for a print job that is stored at the spooling server 

20 50, the spooling server 50 waits for the next query 210 

from the printer polling device 100. Then, instead of its 
normal answer to the query of "NACK" (negative 
acknowledge) 220, the spooling server 50 answers "ACK" 
(acknowledge) 230 and transmits the print job to the 

25 destination printer 120. 
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In an alternate embodiment as shown in Figure 11, an 
agent program 200 provides a directory of documents 204 
to the spooling server 50. The agent program 200 enables 
a client device 12 associated with the print job source 
5 10 to poll the spooling server 50 to determine whether 

the spooling server 50 requires a document 13 identified 
in the directory 204 to complete a print job. If so, the 
document 13 can be uploaded from the client device 12 to 
the spooling server 50. The agent 200 enables a user at a 

10 printer 120 (or using any of the available interfaces to 

the spooling server 50) to initiate the printing of 
documents 13 that still reside on a client device 12 
(such as the user's computer) even though the documents 
13 have not been forwarded to the spooling server 50 as 

15 print jobs. 

The agent program 200 may be downloaded and 
installed on the client device 12. The agent program 200 
may be configured to make the contents of some or all of 
the directories 204 on the client device 12 available to 

20 the spooling server 50. Once installed and running, the 

agent program 200 initiates a connection to the spooling 
server 50 in the same way the printer polling device 100 
does. The agent program may have a connection through a 
firewall, for example. 

25 The directory of documents 204 may include 

application files such as a Microsoft Word .doc file, for 
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example, or files that have been made into a print job 
(Postscript or PDF file) by printing "to a file" from 
some application. 

The directory 204 can be communicated to the 
5 printer polling device 100 and presented at the printer 

polling device 100. Selection of a print job 11 from the 
directory can be made (e.g., via a user interface). 

For example, the spooling server 50 will list those 
documents 13 being available from the agent program 200 

10 whenever the user of that account is interacting with the 

printer polling device 100, or any other interface 
provided for communication to the spooling server 50 as 
described herein. 

For example, the agent program 200 may periodically 

15 poll the spooling server 50 via polling interface 202. 

The interval of the polling can vary as desired and can 
be adjusted dynamically based upon such factors as 
traffic or requests for files. The communications between 
the agent program 200 and the spooling server 50 occur 

20 substantially as described in connection with Figure 6 

above. The polling request (query) 206 is preferably 
encrypted. Because the query 206 is directed to a 
specific spooling server 50, it is difficult for a third 
party to breach the system's security. The query 206 asks 

25 the spooling server 50 if it wants any files in the 

directory 204 (and may also update the directory 204) . 
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Once the spooling server 50 has received a request 207 
from the printer polling device 100 for a document that 
is listed in the directory 204, the spooling server 50 
waits for the next query 206 from the agent program 200. 
5 Then, instead of its normal answer to the query of "NACK" 

(negative acknowledge), it answers "ACK" (acknowledge) 
followed by document information, such as the name of the 
document that is requested by request 207. 

The agent program 200, upon receiving an "ACK" and 

10 the request information 207, opens the document 13 using 

the application it was created in and prints it to a 
temporary file 205 to create a print job 11. This print 
job 11 is then transmitted to the spooling server 50 via 
transmitter 203. The spooling server 50 uses its normal 

15 mechanism to then transmit the print job 11 to the 

destination printer 120. 

Alternatively, the spooling server 50 may send an 
"ACK" followed by the name of a subdirectory. In that 
case, the agent program 200 returns the contents of that 

20 subdirectory. The spooling server 50 can then display 

those files to the user at the printer polling device 100 
and allow one of the files to be selected, or allow 
additional navigation of directory 204 to take place. 
The directory 204 may be presented via a visual 

25 presentation or an audio presentation. The client device 

12 may periodically poll the spooling server 50 to 
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determine whether the spooling server 50 requires a 
document from the directory 204 to complete a print job. 

Communications with the spooling server 50 may be 
enabled via at least one of a telephone, a personal 
5 digital assistant device, a computer, an Internet 

appliance, a web browser, a dedicated terminal, or the 
like. The communications with the spooling server 50 may 
be via an audio interface or a visual interface. 

A communication device for providing status of the 
I;.' 10 print job stored on the spooling server 50 may be 

Z-t provided. The status of the print job may comprise at 

W least one of filename, file size, author, creation date, 

{?: print job lifetime, image, title, contents, personal 

'" t - identification number, recipient, job number, or 

15 reference number. The communication device may be a 

il telephone, a computer, an Internet appliance, a personal 

■Ti digital assistant device, a dedicated terminal, or any 

rl other suitable wireless or wired communication device. 

The print job source 10 may be one of a computer, a 
20 personal digital assistant device, an Internet appliance, 

a telephone, a facsimile machine, a scanner, a dedicated 
terminal, or other suitable source. 

The printer polling device 100 may be capable of 
polling multiple spooling servers. 
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The spooling server 50 may be capable of 
communicating with other servers and receiving a print 
job from at least one of the other servers. 

The print jobs submitted from the print job source 
10 to the spooling server 50 may be generated in a page 
description language known as Postscript. Alternate 
choices for a page description language are PDF, Latex, 
or other similar languages. The size of the paper, 
various printer capabilities, and printable area 
dimensions may be assumed from a lowest common 
denominator set of capabilities common to most of the 
intended target printers. 

Once the destination printer 120 is known, the page 
description language data needs to be converted into a 
form that can be understood by that printer 120. This 
process is shown in Figure 7. Once the print job 11 is 
sent to the spooling server 50, a target printer 120 must 
be identified before the spooling server 50 can forward 
the print job 11 to be printed. Target printer 
identification 801 can be provided with the print job 11 
from the print job source 10 or can be provided by the 
printer polling device 100 as part of the polling query. 
The spooling server 50 retrieves printer specific 
information 805 for the target printer 120 from a printer 
database 803. Based on the printer specific information 
805 (such as data type, page dimensions, color 
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capabilities, margins, and other print characteristics) 
the spooling server 50 will make printer specific 
adjustments 810 to the print job 11 at the page 
description language level prior to rasterization. 
5 On printers that can accept Postscript (or the PDL 

of choice) directly, no modification is necessary. For 
other, simpler printers, a lower level bitmap form of the 
page is required to be sent to the printer. In this case, 
the page description language needs to be rasterized into 

10 a bitmap form. In addition, the bitmap data needs to be 

formatted into the form understood by the printer 120. A 
raster image processor 815 determines the target printer 
type from the printer specific information 805 and 
selects an appropriate data format from available formats 

15 820, 821, 822, 823. The raster image processor 815 places 

the print job 11 into a printer specific data file 850 
for delivery to the printer polling device 100 to be 
printed at the target printer 120. 

One common example of a data format used with simple 

20 printers is PCL (Printer Control Language) , which is 

widely used in printers built by Hewlett Packard. Other 
printers built by Epson, for example use Epson's 
proprietary Epson-escape code sequences to format the 
bitmap data . 
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Alternatively, reformatting of the print job may 
take place at the printer 120, at the printer polling 
device 100, or at any other suitable device. 

Figure 8 shows the components of an embodiment of a 
5 printer polling device 100. As discussed above in 

connection with Figure 3, the printer polling device may 
optionally include a user interface 103 for enabling 
communications with the spooling server 50 (e.g., 
providing a PIN to the spooling server 50) . A polling 

10 transmitter 105 is provided for transmitting polling 

requests to the spooling server 50 via the network 110 to 
identify a print job stored at the spooling server 50 (as 
discussed in connection with Figures 1 and 4 above) . A 
print job receiver 108 is provided for receiving the 

15 identified print job from the spooling server 50 via the 

network 110. Decryption 111 of an encrypted print job may 
optionally be provided for at the printer polling device 
100. A printer interface 112 enables the printer polling 
device 100 to forward the print job to a printer 120 for 

20 printing . 

Figure 9 shows the components of an embodiment of a 
spooling server 50. A receiver 51 is provided which is 
capable of receiving print jobs from the print job source 
10 and receiving polling requests from the printer 

25 polling device 100. The receiver 51 may comprise a print 

job receiver 58 for receiving the print job and a polling 
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receiver 59 for receiving the polling request. When a 
print job is received by the receiver 51, the spooling 
server 50 stores the print job in memory 52, which may 
comprise random access memory (RAM) , magnetic or optical 
5 storage media, or any other read/write memory device. As 

discussed herein, the print jobs may be stored in memory 
52 according to a PIN. Multiple print jobs may be stored 
under each PIN as shown at 53, 54, and 55. When the 
spooling server 50 receives a polling request for a 

10 specific print job from the printer polling device 100 at 

the receiver 51, the spooling server 50 will determine 
whether the requested print job is stored in memory 52, 
and if so, forward the requested print job to the printer 
polling device 100 via transmitter 57. A processor 56 

15 enables the spooling server to search for, retrieve, 

and/or reformat the print job for delivery to the printer 
polling device 100. 

Figure 10 shows the components of an embodiment of a 
print driver 14. An interface 16 is provided for 

20 receiving a print job from a print job source 10. The 

print job source 10 is shown in Figure 10 as a client 
device 12, but can be any suitable print job source as 
discussed herein. The interface 16 receives a printable 
document 13 from the client device 12. A transmitter 18 

25 is provided for transmitting the print job 11 to the 

spooling server 50 via the network 110. The spooling 
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server 50 receives polling requests from the printer 
polling device 100 and forwards one or more identified 
print jobs to the printer polling device 100 in response 
to the polling requests. The print jobs can then be 
5 printed at a printer 120 associated with the printer 

polling device 100. As discussed in greater detail 
elsewhere herein, the printer polling device 100 does not 
have to identify specific print jobs to the spooling 
server 50. Instead, it can simply request a list of all 

10 print jobs (if any) currently stored at the spooling 

server 50 for that specific printer polling device 100, 
or for a particular PIN number (or other identifier) 
entered via the printer polling device 100 or other 
device. As discussed elsewhere herein, the list of print 

15 jobs may be accessed via various other devices capable of 

communicating with the spooling server 50. 

It will now be appreciated that the present 
invention provides improved methods and systems for 
providing printing services over a communications network 

20 in a secure manner without the need to specify the print 

destination. By using a printer polling device, the 
disadvantages of prior art push data flow techniques are 
overcome. Instead of having a remote device initiate 
contact with a print station behind a firewall, the 

25 present invention provides a printer polling device that 

polls a spooling server to determine if there are any 
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documents to be printed by a printer associated with the 
printer polling device. Compatibility with all types of 
printers is also provided. 

Although the invention has been described in 
connection with preferred embodiments thereof, those 
skilled in the art will appreciate that numerous 
adaptations and modifications may be made thereto without 
departing from the spirit and scope of the invention, as 
set forth in the following claims. 
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What is claimed is: 

1. A method of providing printing services, comprising: 

providing a spooling server capable of receiving and 
storing one or more print jobs from a print job source 
via a network; and 

providing a printer polling device capable of 
polling the spooling server via the network to identify a 
print job associated with the printer polling device. 

2. A method in accordance with claim 1, further 
comprising : 

transmitting an identified print job from the 
spooling server to the printer polling device; and 

printing said identified print job at a printer 
coupled to the printer polling device. 

3. A method in accordance with claim 1, wherein said 
printer polling device periodically polls the spooling 
server to identify a print job associated with the 
printer polling device. 

4. A method in accordance with claim 1, wherein the 
network comprises: 

at least one of a local area network, a wide area 
network, a global network, and the Internet. 
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5. A method in accordance with claim 1, wherein: 

said printer polling device is located within a 
gateway firewall; and 

said spooling server is located outside said gateway 

firewall . 

6. A method in accordance with claim 5, wherein: 

the print job is forwarded to the spooling server as 
web-style traffic and received at the printer polling 
device as web-style traffic. 

7. A method in accordance with claim 5, wherein: 

the print job is forwarded to the spooling server 
such that reconfiguration of the gateway firewall is not 
required. 

8. A method in accordance with claim 1, wherein: 

the print job source is located at and in 
communication with a first local area network; 

the printer polling device is located at and in 
communication with a second local area network; and 

the spooling server is located outside of the first 
and second local area networks. 

9. A method in accordance with claim 8, wherein: 
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the print job source communicates with the spooling 
server via a first gateway firewall which controls access 
to the first local area network; and 

the printer polling device communicates with the 
spooling server via a second gateway firewall which 
controls access to the second local area network. 

10. A method in accordance with claim 1, wherein the 
printer polling device is one of (i) a stand-alone device 
connected to the printer via a standard printer port, 

(ii) integrated into the firmware of the printer, or 

(iii) integrated into the software of a network print 
server . 

11. A method in accordance with claim 1, further 
comprising : 

charging a fee to access the spooling server. 

12. A method in accordance with claim 11, wherein the fee 
is based on one of print job size in bytes, print job 
size in number of pages, print job type, time for 
printing, time for storage, monthly fee, per use fee, 
lifetime membership, monthly membership, use of color, 
use of black and white, page size, location, convenience, 
number of images, print quality, or image quality. 
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13. A method in accordance with claim 11, wherein: 

the fee is charged for at least one of providing a 
print job to the spooling server and retrieving a print 
job from the spooling server. 

14. A method in accordance with claim 11, wherein the fee 
can be paid via at least one of (i) a client device 
associated with the print job source; or (ii) the printer 
polling device. 

15. A method in accordance with claim 1, wherein: 

the spooling server stores the one or more print 
job(s) in at least one spooling queue. 

16. A method in accordance with claim 1, further 
comprising : 

providing for encryption of the print job at the 
print job source; and 

providing for decryption of the print job at the 
printer polling device. 

17. A method in accordance with claim 1, wherein the 
print job comprises a document provided by a content 
provider. 
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18. A method in accordance with claim 17, wherein said 
content provider is one of a newspaper, a magazine, a 
periodical, a document provider, a graphic arts provider, 
a notification service, an Internet content provider, a 
merchant, a financial institution, a government agency, 
or a shipping company. 

19. A method in accordance with claim 17, wherein the 
print job is provided by the content provider on a 
subscription basis. 

20. A method in accordance with claim 17, wherein a 
single print job is provided by the content provider for 
multiple users . 

21. A method in accordance with claim 1, wherein the 
printer polling device comprises: 

a user interface; 

a connection to the network; and 

a connection to the printer. 

22. A method in accordance with claim 1, further 
comprising : 

storing each print job on the spooling server 
according to a personal identification number (PIN) . 
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23. A method in accordance with claim 22, further 
comprising: 

communicating from the spooling server to the 
printer polling device a list of print jobs associated 
with the PIN which are stored at the spooling server; 
and 

providing for the selection of a print job. 

24. A method in accordance with claim 22, further 
comprising: 

storing a plurality of print jobs on the spooling 
server according to the PIN. 

25. A method in accordance with claim 22, wherein: 

the PIN is provided to the spooling server via one 
of a user interface associated with the printer polling 
device, a telephone, a computer, an Internet appliance, a 
facsimile machine, a scanner, a personal digital assistant 
device, or a dedicated terminal; 

the list of available print jobs is displayed on one 
of a user interface associated with the printer polling 
device, a telephone, a computer, an Internet appliance, a 
facsimile machine, a scanner, a personal digital assistant 
device, or a dedicated terminal; and 

selection of an available print job is made via a 
user interface associated with the printer polling 
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device, a telephone, a computer, an Internet appliance, a 
facsimile machine, a scanner, a personal digital assistant 
device, or a dedicated terminal. 

26. A method in accordance with claim 1, wherein the 
printer polling device is a portable device. 

27. A method in accordance with claim 1, wherein the 
printer polling device may be operably associated with a 
variety of printer types. 

28. A method in accordance with claim 1, wherein the 
print job is provided to the spooling server without a 
pre-determined print destination. 

29. A method in accordance with claim 1, further 
comprising: 

providing for designation of a desired print 
location for the print job at the print job source; 

providing for communication of the desired print 
location to the spooling server; and 

printing the print job at the desired print location 
when the printer polling device at the desired print 
location polls the spooling server and identifies the 
print job. 
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30. A method in accordance with claim 1, further 
comprising : 

providing for designation of a substantially 
specific time for printing a print job; and 

making said print job available for printing from 
the spooling server only at the designated substantially 
specific time. 

31. A method in accordance with claim 1, further 
comprising : 

providing for a designated lifetime of the print 
job, wherein said print job will be stored only for the 
designated lifetime . 

32. A method in accordance with claim 1, further 
comprising: 

providing for a designated number of printings of 
said print job, wherein said print job can only be 
printed the designated number of times. 

33. A method in accordance with claim 32, wherein: 

the print job is one of a negotiable instrument, a 
stamp, a coupon, a certificate, a check, a unit of 
currency, a token, or a receipt. 

34. A method in accordance with claim 1, further 
comprising: 
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providing for the designation of one or more 
recipients of said print job, wherein the print job can 
only be printed by the designated one or more recipients. 

35. A method in accordance with claim 1, wherein the 
print job source is connected to the network using DHCP 
protocol . 

36. A method in accordance with claim 1, wherein the 
printer polling device is connected to the network using 
DHCP protocol. 

37. A method in accordance with claim 1, wherein the 
printer polling device communicates printer status to the 
spooling server . 

38. A method in accordance with claim 37, wherein the 
printer status comprises at least one of a printer ready 
indication, an on-line indication, toner level 
information, paper supply information, or error 
information . 

39. A method in accordance with claim 37, further 
comprising: 

notifying a printer operator when said printer 
status indicates that the printer requires attention. 
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40. A method in accordance with claim 39, further 
comprising : 

providing the operator with vendor contact 
information to facilitate obtaining printer supplies or 
service . 

41. A method in accordance with claim 37, further 
comprising : 

providing for automatic on-line ordering of printer 
supplies as required by printer status. 

42. A method in accordance with claim 1, wherein the 
print job comprises at least one of a document, a poster, 
an image, a coupon, a ticket, a certificate, a check, a 
list, a schedule, a periodical, a unit of currency, a 
negotiable instrument, postage, a bill of lading, a 
lottery or gaming ticket, a token, food stamps, a 
license, a permit, a pass, a passport, a ballot, a 
citation, identification, a copy-protection key, a proof- 
of-purchase, a warranty, a receipt, a transcript, or a 
library card. 

43. A method in accordance with claim 1, further 
comprising: 
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providing an agent program that provides a directory 
of documents to the spooling server, said agent program 
enabling a client device associated with the print job 
source to poll the spooling server to determine whether 
the spooling server requires a document from the 
directory to complete a print job; and 

uploading the document from the client device to the 
spooling server, 

44. A method in accordance with claim 43, further 
comprising: 

communicating the directory to the printer polling 
device; 

presenting the directory at the printer polling 
device; and 

providing for selection of a print job from the 
directory. 

45. A method in accordance with claim 44, wherein 
presenting said directory comprises one of a visual 
presentation or an audio presentation. 

46. A method in accordance with claim 43, wherein the 
client device periodically polls the spooling server. 
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47. A method in accordance with claim 1, wherein 
communications with the spooling server are enabled via 
at least one of a telephone, a personal digital assistant 
device, a computer, an Internet appliance, a web browser, 
or a dedicated terminal. 

48. A method in accordance with claim 1, wherein 
communications with the spooling server are enabled via 
one of an audio interface or a visual interface, 

49. A method in accordance with claim 1, further 
comprising: 

providing a communication device for providing 
status of the print job stored on the spooling server. 

50. A method in accordance with claim 49, wherein the 
status of the print job comprises at least one of 
filename, file size, author, creation date, print job 
lifetime, image, title, contents, personal identification 
number, recipient, job number, or reference number. 

51. A method in accordance with claim 49, wherein the 
communication device comprises one of a telephone, a 
computer, an Internet appliance, a personal digital 
assistant device, or a dedicated terminal. 
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52. A method in accordance with claim 1, wherein the 
print job source is one of a computer , a personal digital 
assistant device, an Internet appliance, a facsimile 
machine, a scanner, a telephone, or a dedicated terminal. 

53. A method in accordance with claim 1, wherein said 
printer polling device is capable of polling multiple 
spooling servers. 

54. A method in accordance with claim 1, further 
comprising : 

providing for the communication between said 
spooling server and other servers; and 

receiving a print job from at least one of the other 
servers at the spooling server. 

55. A system for providing printing services, comprising: 

a spooling server capable of receiving and storing 
one or more print jobs from a print job source via a 
network; and 

a printer polling device capable of polling the 
spooling server via the network to identify a print job 
associated with the printer polling device. 

56. A system in accordance with claim 55, wherein: 
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an identified print job is transmitted from the 
spooling server to the printer polling device; and 

said identified print job is printed at a printer 
coupled to the printer polling device. 

57. A system in accordance with claim 55, wherein said 
printer polling device periodically polls the spooling 
server to identify a print job associated with the 
printer polling device. 

58. A system in accordance with claim 55, wherein the 
network comprises : 

at least one of a local area network, a wide area 
network, a global network, and the Internet. 

59. A system in accordance with claim 55, wherein: 

said printer polling device is located within a 
gateway firewall; and 

said spooling server is located outside said gateway 
firewall . 

60. A system in accordance with claim 59, wherein: 

the print job is forwarded to the spooling server as 
web-style traffic and received at the printer polling 
device as web-style traffic. 
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61. A system in accordance with claim 59, wherein: 

the print job is forwarded to the spooling server 
such that reconfiguration of the gateway firewall is not 
required. 

62. A system in accordance with claim 55, wherein: 

the print job source is located at and in 
communication with a first local area network; 

the printer polling device is located at and in 
communication with a second local area network; and 

the spooling server is located outside of the first 
and second local area networks. 

63. A system in accordance with claim 62, wherein: 

the print job source communicates with the spooling 
server via a first gateway firewall which controls access 
to the first local area network; and 

the printer polling device communicates with the 
spooling server via a second gateway firewall which 
controls access to the second local area network. 

64. A system in accordance with claim 55, wherein the 
printer polling device is one of (i) a stand-alone device 
connected to the printer via a standard printer port, 
(ii) integrated into the firmware of the printer, or 
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(iii) integrated into the software of a network print 
server . 

65. A system in accordance with claim 55, wherein a fee 
is charged to access the spooling server. 

66. A system in accordance with claim 65, wherein the fee 
is based on one of print job size in bytes, print job 
size in number of pages, print job type, time for 
printing, time for storage, monthly fee, per use fee, 
lifetime membership, monthly membership, use of color, 
use of black and white, page size, location, convenience, 
number of images, print quality, or image quality. 

67. A system in accordance with claim 65, wherein: 

the fee is charged for at least one of providing a 
print job to the spooling server and retrieving a print 
job from the spooling server. 

68. A system in accordance with claim 65, wherein the fee 
can be paid via at least one of (i) a client device 
associated with the print job source; or (ii) the printer 
polling device . 

69. A system in accordance with claim 55, wherein: 
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the spooling server stores the one or more print 
job(s) in at least one spooling queue, 

70. A system in accordance with claim 55, further 
comprising : 

an encryption device for encryption of the print job 
at the print job source; and 

a decryption device for decryption of the print job 
at the printer polling device. 

71. A system in accordance with claim 55, wherein the 
print job comprises a document provided by a content 
provider . 

72. A system in accordance with claim 71, wherein said 
content provider is one of a newspaper, a magazine, a 
periodical, a document provider, a graphic arts provider, 
a notification service, an Internet content provider, a 
merchant, a financial institution, a government agency, 
or a shipping company. 

73. A system in accordance with claim 71, wherein the 
print job is provided by the content provider on a 
subscription basis. 
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74. A system in accordance with claim 71, wherein a 
single print job is provided by the content provider for 
multiple users. 

75. A system in accordance with claim 55, wherein the 
printer polling device comprises: 

a user interface; 

a connection to the network; and 

a connection to the printer. 

76. A system in accordance with claim 55, wherein: 

each print job is stored on the spooling server 
according to a personal identification number (PIN) . 

77. A system in accordance with claim 76, wherein: 

the spooling server communicates to the printer 
polling device a list of print jobs associated with the 
PIN which are stored at the spooling server; and 

the selection of a print job is provided for. 

78. A system in accordance with claim 7 6, wherein: 

a plurality of print jobs are stored on the spooling 
server according to the PIN. 

79. A system in accordance with claim 76, wherein: 
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the PIN is provided to the spooling server via one 
of a user interface associated with the printer polling 
device, a telephone, a computer, an Internet appliance, a 
facsimile machine, a scanner, a personal digital assistant 
device, or a dedicated terminal; 

the list of available print jobs is displayed on one 
of a user interface associated with the printer polling 
device, a telephone, a computer, an Internet appliance, a 
facsimile machine, a scanner, a personal digital assistant 
device, or a dedicated terminal; and 

selection of an available print job is made via a 
user interface associated with the printer polling 
device, a telephone, a computer, an Internet appliance, a 
facsimile machine, a scanner, a personal digital assistant 
device, or a dedicated terminal. 

80. A system in accordance with claim 55, wherein the 
printer polling device is a portable device. 

81. A system in accordance with claim 55, wherein the 
printer polling device may be operably associated with a 
variety of printer types. 

82. A system in accordance with claim 55, wherein the 
print job is provided to the spooling server without a 
pre-determined print destination. 
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83. A system in accordance with claim 55, wherein: 

a desired print location for the print job is 
designated at the print job source; 

the desired print location is communicated to the 
spooling server; and 

the print job is printed at the desired print 
location when the printer polling device at the desired 
print location polls the spooling server and identifies 
the print job. 

84. A system in accordance with claim 55, wherein: 

a substantially specific time for printing a print 
job is designated; and 

said print job is made available for printing from 
the spooling server only at the designated substantially 
specific time . 

85. A system in accordance with claim 55, wherein: 

a lifetime of the print job is designated, wherein 
said print job will be stored only for the designated 
lifetime . 

86. A system in accordance with claim 55, wherein: 
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a number of printings of said print job is 
designated, wherein said print job can only be printed 
the designated number of times. 

87. A system in accordance with claim 86, wherein: 

the print job is one of a negotiable instrument, a 
stamp, a coupon, a certificate, a check, a unit of 
currency, a token, or a receipt. 

88. A system in accordance with claim 55, wherein: 

one or more recipients of said print job are 
designated, wherein the print job can only be printed by 
the designated one or more recipients. 

89. A system in accordance with claim 55, wherein the 
print job source is connected to the network using DHCP 
protocol . 

90. A system in accordance with claim 55, wherein the 
printer polling device is connected to the network using 
DHCP protocol. 

91. A system in accordance with claim 55, wherein the 
printer polling device communicates printer status to the 
spooling server . 
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92. A system in accordance with claim 91, wherein the 
printer status comprises at least one of a printer ready 
indication, an on-line indication, toner level 
information, paper supply information, or error 
information. 

93. A system in accordance with claim 91, wherein: 

a printer operator is notified when said printer 
status indicates that the printer requires attention. 

94. A system in accordance with claim 93, wherein: 

the operator is provided with vendor contact 
information to facilitate obtaining printer supplies or 
service . 

95. A system in accordance with claim 91, wherein: 

automatic on-line ordering of printer supplies as 
required by printer status is provided. 

96. A system in accordance with claim 55, wherein the 
print job comprises at least one of a document, a poster, 
an image, a coupon, a ticket, a certificate, a check, a 
list, a schedule, a periodical, a unit of currency, a 
negotiable instrument, postage, a bill of lading, a 
lottery or gaming ticket, a token, food stamps, a 
license, a permit, a pass, a passport, a ballot, a 
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citation, identification, a copy-protection key, a proof- 
of-purchase, a warranty, a receipt, a transcript, or a 
library card. 

97. A system in accordance with claim 55, further 
comprising: 

an agent program that provides a directory of 
documents to the spooling server, said agent program 
enabling a client device associated with the print job 
source to poll the spooling server to determine whether 
the spooling server requires a document from the 
directory to complete a print job; wherein: 

the document is uploaded from the client device to 
the spooling server. 

98. A system in accordance with claim 97, wherein: 

the directory is communicated to the printer polling 
device; 

the directory is presented at the printer polling 
device; and 

a print job can be selected from the directory. 

99. A system in accordance with claim 98, wherein said 
directory is presented via one of a visual presentation 
or an audio presentation. 
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100. A system in accordance with claim 97, wherein the 
client device periodically polls the spooling server. 

101. A system in accordance with claim 55, wherein 
communications with the spooling server are enabled via 
at least one of a telephone, a personal digital assistant 
device, a computer, an Internet appliance, a web browser, 
or a dedicated terminal. 

102. A system in accordance with claim 55, wherein 
communications with the spooling server are enabled via 
one of an audio interface or a visual interface. 

103. A system in accordance with claim 55, further 
comprising : 

a communication device for providing status of the 
print job stored on the spooling server. 

104. A system in accordance with claim 103, wherein the 
status of the print job comprises at least one of 
filename, file size, author, creation date, print job 
lifetime, image, title, contents, personal identification 
number, recipient, job number, or reference number. 

105. A system in accordance with claim 103, wherein the 
communication device comprises one of a telephone, a 
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computer, an Internet appliance, a facsimile machine, a 
scanner, a personal digital assistant device, or a 
dedicated terminal, 

106. A system in accordance with claim 55, wherein the 
print job source is one of a computer, a personal digital 
assistant device, an Internet appliance, a telephone, a 
facsimile machine, a scanner, or a dedicated terminal. 

107. A system in accordance with claim 55, wherein said 
printer polling device is capable of polling multiple 
spooling servers. 

108. A system in accordance with claim 55, wherein: 
said spooling server is capable of communicating 

with other servers; and 

said spooling server is capable of receiving a print 
job from at least one of the other servers. 
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ABSTRACT 

The present invention relates to methods and systems 
for providing printing services over a communications 
network. In particular, the present invention enables a 
5 user to obtain print jobs at an unspecified location 

which may be remote from the source of the print job. A 
spooling server is used to store a print job received via 
the network from a print job source. A printer polling 
device, which may be at a location remote from the print 

10 job source, is capable of polling the spooling server via 

the network to identify whether any print jobs associated 
with the printer polling device are available for 
printing at an associated printer. The spooling server 
need not initiate contact with the printer through a 

15 firewall, since it is polled by the printer polling 

device. Thus, network security is maintained. A fee can 
be charged for the printing services provided. 
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